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37 CFR 1.111 Amendment dated 10/23/2009 
Reply to Office Action of 07/23/2009 

AMENDMENTS TO THE CLAIMS 

Please cancel claim 3 without prejudice. Kindly amend claims 1-2, 15, 17, and 22 as 
shown in the following listing of claims. The listing of claims will replace all prior 
versions, and listings, of claims in the application: 

Listing of Claims 

1 . (Currently Amended) An apparatus for performing cryptographic operations, 
comprising: 

an x86-compatible microprocessor, comprising: 

an instruction register within a x86-compatible microprocessor having a 
single, atomic cryptographic instruction disposed therein, wherein 
said single, atomic cryptographic instruction is arranged according 
to the instruction format for execution on said x86-compatible 
microprocessor, and wherein said single, atomic cryptographic 
instruction is part of an application program, and wherein said x86- 
compatible microprocessor executes said application program, and 
wherein said single, atomic cryptographic instruction prescribes 
one of the cryptographic oporations an encryption operation , and 
wherein said single, atomic cryptographic instruction prescribes 
that a user-generated key schedule be employed for execution of 
said one of the cryptographic operations encryption operation : 

a keygen unit, operatively coupled to said instruction register, configured 
to direct said x86-compatible microprocessor to load said user- 
generated key schedule; and 

an execution unit, operatively coupled to said keygen unit, configured to 
employ said user-generated key schedule to execute said one of the 
cryptographic opcrations said encryption operation , said execution 
unit comprising: 
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a cryptography unit, configured execute a plurality of 

cryptographic rounds on each of a plurality of input text 
blocks to generate a corresponding each of a plurality of 
output text blocks, wherein said plurality of cryptographic 
rounds are prescribed by a control word that is provided to 
said cryptography unit. 

2. (Currently Amended) The apparatus as recited in claim 1 , wherein said one of the 
cryptographic operations further comprises: encryption operation comprises 
encryption of a plurality of plaintext blocks to generate a corresponding plurality 
of ciphertext blocks. 

an encryption operation, said encryption operation comprising encryption of a 
plurality of plaintext blocks to generate a corresponding plurality of 
ciphertext blocks. 

3. (Cancelled) 

4. (Original) The apparatus as recited in claim 1, wherein said user-generated key 
schedule is stored in memory. 

5. (Original) The apparatus as recited in claim 1 , wherein said user-generated key 
schedule comprises an expanded key schedule according to the Advanced 
Encryption Standard (AES) algorithm. 

6. (Previously Presented) The apparatus as recited in claim 1 , wherein said keygen 
unit is configured to interpret a key generation field within a control word which 
is referenced by said single, atomic cryptographic instruction. 

7. (Cancelled) 

8. (Previously Presented) The apparatus as recited in claim 1, wherein said single, 
atomic cryptographic instruction implicitly references a plurality of registers 
within said x86-compatible microprocessor. 
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9. (Original) The apparatus as recited in claim 8, wherein said plurality of registers 
comprises: 

a first register, wherein contents of said first register comprise a first pointer to a 
first memory address, said first memory address specifying a first location 
in memory for access of said plurality of input text blocks upon which said 
one of the cryptographic operations is to be accomplished. 

10. (Original) The apparatus as recited in claim 8, wherein said plurality of registers 
comprises: 

a second register, wherein contents of said second register comprise a second 
pointer to a second memory address, said second memory address 
specifying a second location in said memory for storage of a 
corresponding plurality of output text blocks, said corresponding plurality 
of output text blocks being generated as a result of accomplishing said one 
of the cryptographic operations upon a plurality of input text blocks. 

1 1 . (Original) The apparatus as recited in claim 8, wherein said plurality of registers 
comprises: 

a third register, wherein contents of said third register indicate a number of text 
blocks within a plurality of input text blocks. 

12. (Original) The apparatus as recited in claim 8, wherein said plurality of registers 
comprises: 

a fourth register, wherein contents of said fourth register comprise a third pointer 
to a third memory address, said third memory address specifying a third 
location in memory for access of cryptographic key data for use in 
accomplishing said one of the cryptographic operations. 

13. (Original) The apparatus as recited in claim 12, wherein said user-generated key 
schedule comprises said cryptographic key data. 
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14. (Original) The apparatus as recited in claim 8, wherein said plurality of registers 
comprises: 

a fifth register, wherein contents of said fifth register comprise a fourth pointer to 
a fourth memory address, said fourth memory address specifying a fourth 
location in memory, said fourth location comprising said initialization 
vector location, contents of said initialization vector location comprising 
an initialization vector or initialization vector equivalent for use in 
accomplishing said one of the cryptographic operations. 

15. (Currently Amended) The apparatus as recited in claim 8, wherein said plurality 
of registers comprises: 

a sixth register, wherein contents of said sixth register comprise a fifth pointer to a 
fifth memory address, said fifth memory address specifying a fifth 
location in memory for access of a control word for use in accomplishing 
said one of the cryptographic operations, wherein said control word 
prescribes cryptographic parameters for said ono of tho cryptographic 



be employed during execution of said one of the cryptographs 
oporations encryption operation . 

16. (Cancelled) 




i, and wherein said control word comprises: 



a keygen field, configured to specify that said user-generated key schedule 
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17. (Currently Amended) An apparatus for performing cryptographic operations, 
comprising: 

a cryptography unit within an x86-compatible microprocessor, configured to 
execute one of the cryptographic operations responsive to receipt of a 
single, atomic cryptographic instruction within an application program 
that prescribes said one of the cryptographic operations a decryption 
operation , wherein said single, atomic cryptographic instruction is 
arranged according to the instruction format for execution on said x86- 
compatible microprocessor, and wherein said x86-compatible 
microprocessor executes said application program, and wherein said 
single, atomic cryptographic instruction also prescribes that a user- 
generated key schedule be employed when executing said decryption 
operation one of the cryptographic operations : and 

a keygen unit, operatively coupled to said cryptography unit, configured to direct 
said x86-compatible microprocessor to perform said one of the 
cryptographic operations and to employ said user-generated key schedule 
when performing said decryption operation one of the cryptographic 

18. (Original) The apparatus as recited in claim 17, wherein said user-generated key 
schedule is stored in memory. 

19. (Original) The apparatus as recited in claim 17, wherein said user-generated key 
schedule comprises an expanded key schedule according to the Advanced 
Encryption Standard (AES) algorithm. 

20. (Previously Presented) The apparatus as recited in claim 17, wherein said keygen 
unit is configured to interpret a key generation field within a control word which 
is referenced by said single, atomic cryptographic instruction. 

21. (Cancelled) 
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22. (Currently Amended) A method for performing cryptographic operations in a 
x86-compatible microprocessor, the method comprising: 

executing an application program that is stored in memory, said executing 
comprising: 

receiving a single, atomic cryptographic instruction from the memory that 
prescribes employment of a user-generated key schedule during 
execution of one of a plurality of cryptographic opcrations an 
encryption operation , wherein the single, atomic cryptographic 
instruction is one of the instructions in the application program, 
wherein the single, atomic cryptographic instruction is arranged 
according to the instruction format for execution on the x86- 
compatible microprocessor; and 

within a cryptographic unit in the x86-compatible microprocessor, employing the 
user-generated key schedule when executing the encryption operation e m 



23. (Previously Presented) The method as recited in claim 22, wherein said receiving 
comprises: 

via a field within a control word that is referenced by the single, atomic 



24. (Original) The method as recited in claim 22, wherein said employing comprises: 
loading the user-generated key schedule from memory. 

25. (Original) The method as recited in claim 22, wherein the user-generated key 
schedule comprises an expanded key schedule according to the Advanced 
Encryption Standard (AES) algorithm. 

26. (Cancelled) 




-to generate a result of the encryption 



opcration ono of the cryptographic operations . 



cryptographic instruction, specifying employment of the user-generated 
key schedule. 
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